import { createApp } from 'vue'

// 引入 ElementPlus 组件
import ElementPlus from 'element-plus'
// 引入 ElementPlus 组件对应的CSS
import 'element-plus/dist/index.css'

//引入 路由
import { router } from './router/index.js'

//引入pinia
import {createPinia} from 'pinia'
const pinia = createPinia()
//引入
import axios from 'axios'

//引入 icons
import * as ElementPlusIconsVue from '@element-plus/icons-vue'

import App from './App.vue'

const app = createApp(App);

//挂载pinia
app.use(pinia)

//定义图片地址全局变量，所有组件都可以使用
app.config.globalProperties.$urlImage = 'http://localhost:8080/images/';

// 是否在启动时生成生产提示
app.config.productionTip = false
// 指定 axios 的全局配置，指定为后端服务器地址
axios.defaults.baseURL = 'http://localhost:8080/'

//指定axios的请求头中携带cookie
axios.defaults.withCredentials = true;

//添加axios请求的拦截器
axios.interceptors.request.use(config => {
    //从本地读取token
    const token = localStorage.getItem('token')
    //判断token是否存在
    if (token) {
        //将token添加到请求头中
        config.headers.Authorization = `${token}`
    }
    return config;
});

// 将 axios 挂载到 Vue 实例
app.config.globalProperties.$axios = axios;

//把icons 添加到 vue 上面
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
    app.component(key, component)
}

//挂载路由
app.use(router)

//挂载到 vue上面
app.use(ElementPlus)

app.mount('#app')
